package com.dvdfe8.crochet.modelo.dao;

import com.dvdfe8.crochet.modelo.entity.Cliente;
import com.dvdfe8.crochet.modelo.entity.Pedido;

import java.util.List;
import org.hibernate.Query;
import org.hibernate.SessionFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;
import org.springframework.transaction.annotation.Transactional;

@Repository
public class PedidoDaoImpl implements PedidoDao {

    @Autowired
    SessionFactory sessionFactory;
    
    @Override
    @Transactional
    public void crear(Pedido pedido) { 
        sessionFactory.getCurrentSession().saveOrUpdate(pedido);
    }

    @Override
    @Transactional
    public List<Pedido> listarTodos() {
        String hql = "from Pedido";
        Query query = sessionFactory.getCurrentSession().createQuery(hql);
        return query.list();
    }

    @Override
    public List<Pedido> listarTodos(Cliente cliente) {        
        String hql = "from Pedido as ped where ped.cliente=cliente";
        Query query = sessionFactory.getCurrentSession().createQuery(hql);
        return query.list();
    }
    
    @Override
    @Transactional
    public void eliminar(Pedido pedido) {
        sessionFactory.getCurrentSession().delete(pedido);
    }

    @Override
    @Transactional
    public Pedido getPedidoById(int id) {
        String hql = "from Pedido where id=" + id;
        Query query = sessionFactory.getCurrentSession().createQuery(hql);
        return (Pedido) query.list().get(0);
    }    
    
}
